<!--
  ~ Copyright 2024 Apollo Authors
  ~
  ~ Licensed under the Apache License, Version 2.0 (the "License");
  ~ you may not use this file except in compliance with the License.
  ~ You may obtain a copy of the License at
  ~
  ~ http://www.apache.org/licenses/LICENSE-2.0
  ~
  ~ Unless required by applicable law or agreed to in writing, software
  ~ distributed under the License is distributed on an "AS IS" BASIS,
  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  ~ See the License for the specific language governing permissions and
  ~ limitations under the License.
  ~
-->
<!doctype html>
<html ng-app="role">

<head>
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  <link rel="icon" href="../img/config.png">
  <!-- styles -->
  <link rel="stylesheet" type="text/css" href="../vendor/bootstrap/css/bootstrap.min.css">
  <link rel="stylesheet" type="text/css" href="../vendor/angular/angular-toastr-1.4.1.min.css">
  <link rel="stylesheet" type="text/css" media='all' href="../vendor/angular/loading-bar.min.css">
  <link rel="stylesheet" type="text/css" href="../styles/common-style.css">
  <link rel="stylesheet" type="text/css" href="../vendor/select2/select2.min.css">
  <title>{{'Cluster.Role.Title' | translate }}</title>
</head>

<body>

<apollonav></apollonav>

<div class="container-fluid apollo-container">
  <section class="panel col-md-offset-1 col-md-10" ng-controller="ClusterNamespaceRoleController">
    <header class="panel-heading">
      <div class="row">
        <div class="col-md-9">
          <h4 class="modal-title">
            {{'Cluster.Role.Title' | translate }}
            <small>
              (
              {{'Common.AppId' | translate }}:
              <label ng-bind="pageContext.appId"></label>
              {{'Common.Environment' | translate }}:
              <label ng-bind="pageContext.env"></label>
              {{'Common.ClusterName' | translate }}:
              <label ng-bind="pageContext.clusterName"></label>
              )
            </small>
          </h4>
        </div>
        <div class="col-md-3 text-right">
          <a type="button" class="btn btn-info" data-dismiss="modal"
             href="{{ '/app/manage_cluster.html' | prefixPath }}?#appid={{pageContext.appId}}">{{'Common.ReturnToManageClusterPage' | translate }}
          </a>
        </div>
      </div>
    </header>
    <div class="panel-body" ng-show="hasAssignUserPermission">
      <div class="row">
        <div class="form-horizontal">
          <div class="form-group">
            <label
                class="col-sm-2 control-label">{{'Cluster.Role.GrantModifyTo' | translate }}<br><small>{{'Cluster.Role.GrantModifyTo2' | translate }}</small></label>
            <div class="col-sm-8">
              <form class="form-inline" ng-submit="assignRoleToUser('ModifyNamespacesInCluster')">
                <div class="form-group">
                  <apollouserselector apollo-id="modifyRoleWidgetId"></apollouserselector>
                </div>
                <button type="submit" class="btn btn-default" style="margin-left: 20px;"
                        ng-disabled="modifyRoleSubmitBtnDisabled">{{'Cluster.Role.Add' | translate }}</button>
              </form>
              <!-- Split button -->
              <div class="item-container">
                <div class="btn-group item-info"
                     ng-repeat="user in rolesAssignedUsers.modifyRoleUsers">
                  <button type="button" class="btn btn-default" ng-bind="user.userId"></button>
                  <button type="button" class="btn btn-default dropdown-toggle"
                          data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"
                          ng-click="removeUserRole('ModifyNamespacesInCluster', user.userId)">
                    <span class="glyphicon glyphicon-remove"></span>
                  </button>
                </div>
              </div>
            </div>
          </div>
        </div>
        <hr>

        <div class="row" style="margin-top: 10px;">
          <div class="form-horizontal">
            <div class="col-sm-2 text-right">
              <label
                  class="control-label">{{'Cluster.Role.GrantPublishTo' | translate }}<br><small>{{'Cluster.Role.GrantPublishTo2' | translate }}</small></label>
            </div>
            <div class="col-sm-8">
              <form class="form-inline" ng-submit="assignRoleToUser('ReleaseNamespacesInCluster')">
                <div class="form-group">
                  <apollouserselector apollo-id="releaseRoleWidgetId"></apollouserselector>
                </div>
                <button type="submit" class="btn btn-default" style="margin-left: 20px;"
                        ng-disabled="ReleaseRoleSubmitBtnDisabled">{{'Cluster.Role.Add' | translate }}</button>
              </form>
              <!-- Split button -->
              <div class="item-container">
                <div class="btn-group item-info"
                     ng-repeat="user in rolesAssignedUsers.releaseRoleUsers">
                  <button type="button" class="btn btn-default" ng-bind="user.userId"></button>
                  <button type="button" class="btn btn-default dropdown-toggle"
                          data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"
                          ng-click="removeUserRole('ReleaseNamespacesInCluster', user.userId)">
                    <span class="glyphicon glyphicon-remove"></span>
                  </button>
                </div>
              </div>
            </div>
          </div>

        </div>

      </div>


    </div>
    <div class="panel-body text-center" ng-show="!hasAssignUserPermission">
      <h2>{{'Cluster.Role.NoPermission' | translate }}</h2>
    </div>

  </section>
</div>

<div ng-include="'../views/common/footer.html'"></div>

<!-- jquery.js -->
<script src="../vendor/jquery.min.js" type="text/javascript"></script>

<!--angular-->
<script src="../vendor/angular/angular.min.js"></script>
<script src="../vendor/angular/angular-resource.min.js"></script>
<script src="../vendor/angular/angular-toastr-1.4.1.tpls.min.js"></script>
<script src="../vendor/angular/loading-bar.min.js"></script>
<script src="../vendor/angular/angular-cookies.min.js"></script>

<script src="../vendor/angular/angular-translate.2.18.1/angular-translate.min.js"></script>
<script src="../vendor/angular/angular-translate.2.18.1/angular-translate-loader-static-files.min.js"></script>
<script src="../vendor/angular/angular-translate.2.18.1/angular-translate-storage-cookie.min.js"></script>

<!-- bootstrap.js -->
<script src="../vendor/bootstrap/js/bootstrap.min.js" type="text/javascript"></script>

<script src="../vendor/select2/select2.min.js" type="text/javascript"></script>

<!--biz-->
<!--must import-->
<script type="application/javascript" src="../scripts/app.js"></script>
<script type="application/javascript" src="../scripts/services/AppService.js"></script>
<script type="application/javascript" src="../scripts/services/EnvService.js"></script>
<script type="application/javascript" src="../scripts/services/UserService.js"></script>
<script type="application/javascript" src="../scripts/services/CommonService.js"></script>
<script type="application/javascript" src="../scripts/services/PermissionService.js"></script>

<script type="application/javascript" src="../scripts/AppUtils.js"></script>

<script type="application/javascript" src="../scripts/PageCommon.js"></script>
<script type="application/javascript" src="../scripts/directive/directive.js"></script>

<script type="application/javascript" src="../scripts/controller/role/ClusterNamespaceRoleController.js"></script>
</body>

</html>